/**
 * The ToC is now generated in the page template so
 * it even exists for users without client-side js
 * and that means it loads with the page so it avoids
 * all potential reshuffling or layout recalculations.
 * 
 * So, all this function needs to do is make the links
 * perform smooth animation, and adjust the "active"
 * entry as the user scrolls.
 */
export default function setupToC() {
    const toc = document.getElementById("toc");
    if (!toc) return;

    // Get all relevant elements
    const sections = document.getElementById("content")!.querySelectorAll("h2, h3, h4, h5, h6");
    const links = toc.querySelectorAll("a");

    // Setup smooth scroll on click
    for (const link of links) {
        link.addEventListener("click", e => {
            const target = document.querySelector(link.getAttribute("href")!);
            if (!target) return;
            e.preventDefault();
            e.stopPropagation();
            
            target.scrollIntoView({behavior: "smooth"});
        });
    }

    // Setup a moving "active" in the ToC that adjusts with the scroll state
    function changeLinkState() {
        let index = sections.length;

        // Work backkwards to find the first matching section
        while (--index && window.scrollY + 50 < (sections[index] as HTMLElement).offsetTop) {} // eslint-disable-line no-empty

        // Update the "active" item in ToC
        links.forEach((link) => link.classList.remove("active"));
        links[index].classList.add("active");
    }
    
    // Initial render
    changeLinkState();
    window.addEventListener("scroll", changeLinkState);
}